不 是 很 系统 , 想到 哪 讲 到 哪 





县 
漫谈 ” 反 木 选 


(DOwkiken 





旦 构 的 时 候 





我 们 想 达 到 的 状态 
图 3-1 开发 人 员 对 遗留 代码 的 态度 图 谱 


你 是 什么 风格 ? 





兄 制 的 激进 派 


架构 设计 





。 演 进 式 设计 : 系统 的 设计 随 着 系统 实现 的 增长 而 增长 (敏捷 ) 
。 计划 式 设 计 : 在 项 目 构 建 开 始 之 前 , 惑 非 音 详细 地 制定 各 种 计划 (桥梁 施工 ) 
。 最 小 计划 陈设 计 : 20% 的 计划 式 , 80% 的 演进 式 


不 同 项目 
或 者 同一 个 项 目的 不 同 阶段 ， 
采取 的 宋 略 不 一 桂 ! 


架构 设计 





没有 最 完美 的 设计 


只 有 最 合 适 的 设计 





。 四 板 弃 : 
需求 分 析 
方案 调研 
方案 对 比 
万 案 确定 


需求 分 析 





“ 需求 是 什么 ? 
* 约束 是 什么 ? 
人 

是 什么 ? 


需求 分 析 : 风险 动 模 王 





运用 最 小 的 如 构 扩 术 集合 去 降低 最 么 迫 的 风险 ， 
以 求 事半功倍 


“ 步骤 
” 认 别 风险 , 并 排 定 优先 级 (从 需求 出 发 ) 
* 选择 并 运用 一 组 扩 术 
“评估 风险 降低 的 程度 


需求 分 析 : what & how 





1. 我 不 知道 要 做 什么 
2. 我 好 像 知 道 要 做 什么 
3. 我 明确 知道 不 能 做 什么 
4. 我 明确 知道 要 做 什么 
5. 我 明确 知道 要 怎么 做 


幸 全 





你 现 
在 
本 
天 
的 
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人 
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本 人 
3 .1 有 


方案 调研 : 资料 收集 





。 搜 索 : Google & Github 
。 书 /Github star/ 日 单 阅读 /笔记 库 
。 现 有 已 知 的 项 目 是 售 有 类似 的 方案 ? 


What you should do daily? 没 吃 过 猪肉 还 没 见 过 猪 跑 。? 
1， 看 各 种 以 构 方 案 

2， 看 各 种 `in actiom 实践 , 例如 Redis in Action/RabbitMQ in Action/Kubernetes in Action 

3， 看 各 种 网 上 的 文章 (碎片 化 ) 


方案 调研 : 方 同 





* 业务 竞 品 : 主要 看 文档 -能 力 版 图 / 领 苔 知识 
* 开 产 : 看 实现 
* 类 似 方案 : 看 机 制 


方案 调研 : APIGateway 例 子 





*。 业界 : AWS/ 阿 里 云 /腾讯 云 / 左 耳 水 耗子 MegaEase APlgateway( 文 档 ) 
。 开 妆 : 

。Openresty: Kong (文档 ) 

。GO: Tyk / KrakenD / Janus (实现 ) 

。 国 内 开发 者 :Apache APlISIX https://github.com/apache/apisix 
。 关 似 方 案 : 非 网 关 traefik / Go 版 本 的 翻 场 代理 (机 制 |) 


方案 调研 : APIGateway 例 子 





CNCF Cloud Native Interactive Landscape 


The Cloud Native Trail Map (png, pdf) is CNCF's recommended path through the cloud native landscape. The cloud native landscape (png, pdf), serverless landscape (png, pdf), and 


member landscape (png, pdf) are dynamically generated below. Please open a pull request to correct any issues. Greyed logos are not open source. Last Updated: 2020-08-08 00:24:03Z 


You are viewing 13 cards with a total of 58,150 stars, market cap of $S1.14T and funding of $S132.38M. 


Landscape Card Mode Serverless 


Orchestration & Management - API Gateway (13) 


红 


Ambassador 


SCALE 





3Scale 202 
Red Hat MCap: $S111.29B 


Ambassador 


Datawire 


人 2.874 
Funding: S4.25M 


O 〇 
沁 Cey 


KrakenD Platform 


KrakenD 人 福 2.960 


Brutale 


WO 人 


API Microgateway 


Mia-Platform 


Mia-Platform 


WS0O2 API Microgateway [176 
WSO2 Funding: $S40.5M 


Members 
APIOAK 司 瑚 1 三 1X 
APIOAK 320 APISIX 仿 3.077 
APIOAK Apache Software Foundation 


人 @ Reactive 
候 Interaction 
Gateway 


Reactive Interaction 〖K430 
Gateway MCap: $147.49B 
Accenture 


MuleSoft 


MuleSoft 宾 139 


Salesforce MCap: S181.15B 


Clod 


Gloo 2.497 
solo.io Funding: $S13.5M 
Sentinel 
Sentinel K13.232 
Alibaba Cloud MCap: $695.69B 


CLOUD NATIVE 


COMPUTINC FOUNDATION 


1186 


共 Kong 


Kong 真 26,561 
Kong Funding: $S69.1M 
Tyk 5.682 
Tyk Funding: $5.03M 


TITRET 于 





你 必须 完全 知 道 
每 一 个 ` 关 键 细 下 
是 如 何 实 现 的 ! 


方案 调研 : 调研 到 什么 程度 ? 





对 于 权限 中 心 来 说 , 策略 表达 陈 是 ` 核 心 、 
对 于 APlGateway 来 说 , 如 何 ` 代 理 ` 并 ` 管 理 连接 ` 是 核心 


例子 : APlGateway 技术 选 型 的 时 候 , 怎么 做 代理 ? 如何 同 时 支持 websocket? 开 源 的 几 个 项 目 , 各 自如 何 实现 的 ? 


。 httputil.ReverseProxy was updated in Go 1.12 to support websockets automatically.issues / 对 应 commit / 源码 ，httputil 对 
websocket 转发 处 理 ， 参 考 源 码 的 handleUpgradeResponse 方法 


Janus: httputil.ReverseProxy 
net/http/httputil Go 1.15 


ReverseProxy now supports not modifying the X-Forwarded-For header whenthe incoming Request .Header map entry 
forthat field is niIL. 


When a Switching Protocol (like WebSocket) request handled by ReverseProxy is canceled, the backend connection is now 
correctly closed. 


方案 对 比 





人 有 最 完美 的 方案 
只 有 最 合适 的 方案 
全 站 二 机 并 期 鹿 


上 每 个 方案 的 ; 现实 ` 是 什么 ? 
2. 你 的 "期望 ， (需求 ) 是 什么 ? 


方案 对 比 : 合适 原则 





合适 原则 : 合适 优 于 业 寞 领先 


简单 原则 : 简单 优 于 复 香 九 谨 
睾 单 原则 : 简单 优 于 复杂 刀 吕 | 人 归 42 
演化 原则 : 演化 优 于 一 步 到 位 受 朱 又 仁 入 


"合适 但 是 也 不 能 太 沙 后 
"简单 但 是 要 能 满足 现在 以 及 未 来 可 见 泄 围 内 的 需求 
"演化 但 是 撒 子 要 好 , 必须 要 蜗 在 起 跑 线 


方案 对 比 : 选择 开发 框架 





Benchmark of different processing time 
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https://sgithub.com/smallnest/go-web-framework-benchmark 


方案 对 比 : Why chi? 





Why APlIGateway choose chi 


chiis alightweight, idiomatic and composable router for building Go HTTP services. 
Features 


。 Lightweight - cloc'd in ~1000 LOC forthe chi router 

。 Fast - yes, see benchmarks 

。 Designed for modular/composable APls - middlewares, inline middlewares, route groups and subrouter mounting 
。 Context control - built on new context package, providing value chaining, cancelations and timeouts 

。 Robust -in production at Pressly CloudFlare, Heroku, 99Designs, and many others (see discussiomn) 


。 Doc generation - docgen auto-generates routing documentation from your source to JSON or Markdown 


。 No external dependencies - plain ol Go stdlib + net/http 


方案 对 比 : Why gin? 





Why IAM choose ginr 


Gin is a web framework written in Go (Golang). Itfeatures a martini-like API with performance that is up 
to 40 times fasterthanks to httprouter fyou need performance and good productivity you will love Gin. 


Router 
Validation 
Middleware & Response 


方案 对 比 : 稳定 依赖 原则 





稳定 依赖 原则 : 依赖 关系 必须 要 指向 更 稳定 的 方向 . 预期 
会 经 常 变更 的 组 件 都 不 应 该 被 一 个 难以 修改 的 组 件 所 依 
赖 否则 这 个 多 变 的 组 件 也 将 会 变 得 难以 被 修改 


稳定 性 指标 = 出 依赖 /出 依赖 + 入 依赖 ) 


活跃 度 如 何 ? 发 布 频率 ?最 后 一 个 稳定 版 之 后 的 
issue 有 哪些 关键 的 疝 未 解决 ? 


确定 方案 : 技术 债务 





风险 驱动 模型 意味 着 茶 段 时 间 内 资产 有 限 的 情况 下 
只 能 天 注 示 个 核心 
如 宁 做 取舍 , 融会 估 债 ! 





可 逆 的 决 案 , 需要 理性 看 待 , 主要 考虑 变更 的 成 本 | 
不 可 秘 的 决 守 , 需要 谨 蛋 评估 | 


开 己 没有 回头 箭 , 决定 了 就 只 能 一 路 直到 


确定 方案 : 时 刻 天 注 更 新 





Read the change log! 


Feature + Bugfix + 性 能 





难以 决 案 的 时 候 的 一 种 选择 


确定 方案 : 推迟 决策 





。 一 个 系统 中 最 消耗 人 力 资源 的 是 什么 ? 系统 中 存在 的 耦合 -尤其 是 那些 过 早 做 出 
的 , 不 成 烈 的 决策 所 导致 的 耦合 . 那些 决策 与 系统 业务 需求 (用 例 ) 无 关 的 , 细 世 性 
的 决策 ( 框 避 / 数 据 库 /web 服 务 器 /工具 库 / 依 赖 注入 等 ) 应 该 是 辅助 的 , 可 以 被 推 
迟 . 

” 一 个 设计 良好 的 系统 习 构 不 应 该 依赖 于 这 些 细 区 , 而 应 该 尽 可 能 地 推迟 这 些 细 
玫 性 的 决策 , 并 致力 于 将 这 种 推迟 所 产生 的 影响 降 到 最 低 ， 


。 未 来 会 遇 到 的 需要 提前 和 考虑 方案 扩展 性 , 但 是 不 做 决策 . 例如 Redis 
缓存 未 来 单 实 例 抗 不 住 , 用 sharding? Cluster? 


确定 方案 : 可 扩展 性 





协议 上 文 持 , 但 是 不 实现 
接口 上 文 持 , 但 是 不 开放 
人 存储 上 文 持 , 但 是 不 使 用 


看 得 足够 远 , 惑 不 担心 需求 频繁 
保 留 未 来 的 可 能 


确定 万 案 : 每 一 个 选择 都 需 谨慎 





无 论 大 小 /无 关 难 易 


* 为 什么 我 们 售 并 了 GORM 而 转 问 sqlx( 最 后 一 个 版 本 2018)? 
* 为 什么 我 们 后 妆 用 Go, 表 病 用 Django( 而 不 是 GO 

* 为 什么 CMDB 是 微服 务 框 染 而 我 们 不 是 ? 

。 为 什么 APIGateway 的 go-redis ratelimit 没 有 升级 到 最 新 ? 





反 术 选 型 是 需要 在 日 单项 目 中 不 断 ` 磨 练 ` 的 一 种 意 认 


QSA 


END 


